home *** CD-ROM | disk | FTP | other *** search
/ The Atari Compendium / The Atari Compendium (Toad Computers) (1994).iso / files / umich / network / ka9q / ka9q_src.arc / LAPB.H < prev    next >
C/C++ Source or Header  |  1988-07-28  |  3KB  |  82 lines

  1. /* Upper sub-layer (LAPB) definitions */
  2.  
  3. /* Control field templates */
  4. #define    I    0x00    /* Information frames */
  5. #define    S    0x01    /* Supervisory frames */
  6. #define    RR    0x01    /* Receiver ready */
  7. #define    RNR    0x05    /* Receiver not ready */
  8. #define    REJ    0x09    /* Reject */
  9. #define    U    0x03    /* Unnumbered frames */
  10. #define    SABM    0x2f    /* Set Asynchronous Balanced Mode */
  11. #define    DISC    0x43    /* Disconnect */
  12. #define    DM    0x0f    /* Disconnected mode */
  13. #define    UA    0x63    /* Unnumbered acknowledge */
  14. #define    FRMR    0x87    /* Frame reject */
  15. #define    UI    0x03    /* Unnumbered information */
  16. #define    PF    0x10    /* Poll/final bit */
  17.  
  18. #define    MMASK    7    /* Mask for modulo-8 sequence numbers */
  19.  
  20. /* FRMR reason bits */
  21. #define    W    1    /* Invalid control field */
  22. #define    X    2    /* Unallowed I-field */
  23. #define    Y    4    /* Too-long I-field */
  24. #define    Z    8    /* Invalid sequence number */
  25.  
  26. /* Per-connection link control block
  27.  * These are created and destroyed dynamically,
  28.  * and are indexed through a hash table.
  29.  * One exists for each logical AX.25 Level 2 connection
  30.  */
  31. struct ax25_cb {
  32.     struct ax25_cb *next;        /* Doubly linked list pointers */
  33.     struct ax25_cb *prev;
  34.  
  35.     struct mbuf *txq;        /* Transmit queue */
  36.     struct mbuf *rxasm;        /* Receive reassembly buffer */
  37.     struct mbuf *rxq;        /* Receive queue */
  38.  
  39.     struct ax25 addr;        /* Address header */
  40.  
  41.     struct interface *interface;    /* Associated interface */
  42.  
  43.     char rejsent;            /* REJ frame has been sent */
  44.     char remotebusy;        /* Remote sent RNR */
  45.     char waitack;            /* Wait for F-bit ack */
  46.     char response;            /* Response owed to other end */
  47.  
  48.     char vs;            /* Our send state variable */
  49.     char vr;            /* Our receive state variable */
  50.     char unack;            /* Number of unacked frames */
  51.     int maxframe;            /* Transmit flow control level */
  52.     int16 paclen;            /* Maximum outbound packet size */
  53.     int16 window;            /* Local flow control limit */
  54.     char proto;            /* Protocol version */
  55. #define    V1    0            /* AX.25 Version 1 */
  56. #define    V2    1            /* AX.25 Version 2 */
  57.     unsigned retries;        /* Retry counter */
  58.     unsigned n2;            /* Retry limit */
  59.     int state;            /* Link state */
  60. #define    DISCONNECTED    0
  61. #define    SETUP        1
  62. #define    DISCPENDING    2
  63. #define    CONNECTED    3
  64. #define    FRAMEREJECT    4
  65.     char frmrinfo[3];        /* I-field for FRMR message */
  66.     struct timer t1;        /* Retry timer */
  67.     struct timer t2;        /* Acknowledgement delay timer */
  68.     struct timer t3;        /* Keep-alive poll timer */
  69.  
  70.     void (*r_upcall)();        /* Receiver upcall */
  71.     void (*t_upcall)();        /* Transmit upcall */
  72.     void (*s_upcall)();        /* State change upcall */
  73.     char *user;            /* User pointer */
  74. };
  75. #define    NULLAX25    ((struct ax25_cb *)0)
  76. extern struct ax25_cb ax25default;
  77. extern struct ax25_cb *ax25_cb[];
  78. #define    NHASH    17
  79.  
  80. #define    YES    1
  81. #define    NO    0
  82.